草庐IT

Pythonic 相当于 unshift 或 redo?

全部标签

ruby - ruby 数组中 shift/unshift 的运行时间是多少

有人知道ruby​​数组中的shift和unshift有多高效吗?从数组的开头删除并且必须移动内存中的每个元素会变得非常低效。我假设ruby​​以其他方式做到这一点。以下任何信息都会有所帮助:-算法运行时-实现-一般效率-shift/unshift是否可以用于队列(在C++之类的东西中这不会)谢谢! 最佳答案 在旧版本的Ruby中(~2012之前),unshift是一个O(n)操作。但是,在thiscommit中添加了优化和releasedinRuby2.0.0这使得unshift摊销O(1),这意味着它保证平均为O(1),但单个操

ruby - 相当于其他语言ruby中方法名的感叹号

在Ruby中,具有副作用的方法或更改作为参数传递的对象的方法带有“!”作为后缀。例如:"SomeString".gsub!(/S/,"s")将更改String对象,而"SomeString".gsub(/S/,"s")将处理String对象的副本,并且不会更改方法之外的任何对象的状态。我喜欢这个约定,我也想在用其他语言编程时使用它。我的问题:真正的Ruby程序员(我不是;-))真的使用这个约定吗?如果不是,为什么不呢?在Java、PHP、Perl、Cobol中是否有等效的命名方法约定...? 最佳答案 Bang方法并不意味着“改变接

Ruby 相当于 Python 的 "array[i:]"选择 i 之后的所有数组元素?

我发现自己想要类似Python的东西ary=[1,2,3,4,5,6,7,8]ary[2:]#=>[3,4,5,6,7,8]这些天所有的时间。解决方案最终总是多行且丑陋。我想知道最优雅的解决方案可能是什么,因为我的不值得展示。 最佳答案 使用Array#drop2.1.0:019>ary.drop(2)=>[3,4,5,6,7,8] 关于Ruby相当于Python的"array[i:]"选择i之后的所有数组元素?,我们在StackOverflow上找到一个类似的问题:

ruby-on-rails - 相当于 ruby​​/rails 中的 Array.some

我想在rails中做Array.some的等价物。这是一个应用于我的用例的示例,它是一种更复杂的include?(我想将其应用于*args):ary=[:a,:b,:c,d::x,e::y]#=>[:a,:b,:c,{:d=>:x,:e=>:y}]search=:econtained=ary.some{|x|x==search||x.try(:key?,search)}#=>trueassertcontained,"Weshouldhavefound#{search}"我可以用ary.map来做到这一点,但这意味着遍历整个数组然后再次测试它的内容。我还可以使用ary.drop_whil

ruby-on-rails - 什么是 ruby​​ 相当于 python 的 getattr

我是Rails的新手,正在尝试进行一些重构(在app/views/shared中放置一个列出标题的部分渲染器)渲染器显示日期和标题。但是渲染器的不同用户使用不同的日期。通过重构,我有一部分title_date=list_titles.created_on对于我想要的渲染器的其他用户title_date=list_titles.updated_on那么我可以使用我传递的字符串吗(使用:locals参数)?我知道在Python中我可以做到date_wanted='created_on'title_date=getattr(list_titles,date_wanted)但我不知道如何在ru

Ruby String#scan 相当于返回 MatchData

正如问题标题中所述,Ruby字符串上是否有等效于String#Scan的方法?但不是只返回每个匹配项的列表,而是返回一个MatchData数组?例如:#Matchesasetofcharactersbetweenunderscorepairs"foo_bar__baz_hashbang".some_method(/_[^_]+_/)#=>[#<MatchData"_bar_"&rt,<MatchData"_baz_"&rt]或者任何我能得到相同或相似结果的方法都是好的。我想这样做是为了找到Ruby字符串中“字符串”的位置和范围,例如"goodbyeand"world"insid

ruby - 相当于 Iconv.conv ("UTF-8//IGNORE",...) 在 Ruby 1.9.X 中?

我正在从远程源读取数据,偶尔会得到一些采用另一种编码的字符。它们并不重要。我想得到一个“最佳猜测”的utf-8字符串,并忽略无效数据。主要目标是获得一个我可以使用的字符串,并且不会遇到以下错误:Encoding::UndefinedConversionError:从ASCII-8BIT到UTF-8的“\xFF”:utf-8中的无效字节序列 最佳答案 我以为是这样:string.encode("UTF-8",:invalid=>:replace,:undef=>:replace,:replace=>"?")将用“?”替换所有已知项。要

ruby - (Mac) 当语法设置为 Ruby 时 Vim 相当慢

我在MacVim7.4(我使用命令行版本)上,通过Homebrew安装。Vim在语法高亮Ruby代码时很慢。htop在vi​​m中移动Ruby文件时显示80%-100%的CPU使用率。我在SO上找到了这些:VimslowwithrubysyntaxhighlightingSyntaxhighlightingcausesterriblelaginVim并尝试了建议的解决方案。我做了什么:setregexpengine=1:没有任何改变。CPU使用率仍然很高,性能很慢。设置lazyredraw:事情变得更好,但权衡非常明显(光标在移动时消失)我检查了.vimrc中的autocmd语句,没有

相当于 Perl Data::Dumper 的 Ruby

我正在学习Ruby和Perl有一个非常方便的模块,称为Data::Dumper,它允许您递归地分析数据结构(如哈希)并允许您打印它。这在调试时非常有用。Ruby有类似的东西吗? 最佳答案 看pp例子:require'pp'x={:a=>[1,2,3,{:foo=>bar}]}ppx还有一个inspect方法也很好用x={:a=>[1,2,3,{:foo=>bar}]}putsx.inspect 关于相当于PerlData::Dumper的Ruby,我们在StackOverflow上找到一

Ruby gem 相当于 "pip install -e"?

在Python中,我可以从"editable"mode中的源安装一个包使用pipinstall-e。然后我可以继续编辑代码,任何更改都会被importlibrary的其他Python脚本自动选取开发Rubygem是否有类似的工作流程?在开发库时使用库的“Ruby方式”是什么,而不是每次我对源代码进行更改时编译和安装gem? 最佳答案 bundler有两种常见的方法:执行bundleinstall--pathvendor/bundle并且不运行bundleupdate除非一切都经过测试。告诉打包器使用本地版本的gem:在Gemfile